std::literals::string_view_literals:: operator""sv
From cppreference.net
<
cpp
|
string
|
basic string view
|
헤더에 정의됨
<string_view>
|
||
|
constexpr
std::
string_view
operator "" sv ( const char * str, std:: size_t len ) noexcept ; |
(1) | (C++17부터) |
|
constexpr
std::
u8string_view
operator "" sv ( const char8_t * str, std:: size_t len ) noexcept ; |
(2) | (C++20부터) |
|
constexpr
std::
u16string_view
operator "" sv ( const char16_t * str, std:: size_t len ) noexcept ; |
(3) | (C++17부터) |
|
constexpr
std::
u32string_view
operator "" sv ( const char32_t * str, std:: size_t len ) noexcept ; |
(4) | (C++17부터) |
|
constexpr
std::
wstring_view
operator "" sv ( const wchar_t * str, std:: size_t len ) noexcept ; |
(5) | (C++17부터) |
문자 리터럴의 문자열 뷰를 형성합니다.
1)
반환값
std::
string_view
{
str, len
}
.
2)
반환값
std::
u8string_view
{
str, len
}
.
3)
반환값
std::
u16string_view
{
str, len
}
.
4)
반환값
std::
u32string_view
{
str, len
}
.
5)
반환값
std::
wstring_view
{
str, len
}
.
목차 |
매개변수
| str | - | 원시 문자 배열 리터럴의 시작을 가리키는 포인터 |
| len | - | 원시 문자 배열 리터럴의 길이 |
반환값
참고 사항
이 연산자들은 네임스페이스
std::literals::string_view_literals
에서 선언되며, 여기서
literals
와
string_view_literals
는 모두 인라인 네임스페이스입니다. 이 연산자들에 접근하려면 다음 중 하나를 사용하면 됩니다:
- using namespace std :: literals ,
- using namespace std :: string_view_literals , 또는
- using namespace std :: literals :: string_view_literals .
예제
이 코드 실행
#include <iostream> #include <string_view> #include <typeinfo> void print_each_character(const std::string_view sw) { for (char c : sw) std::cout << (c == '\0' ? '@' : c); std::cout << '\n'; } int main() { using namespace std::literals; std::string_view s1 = "abc\0\0def"; std::string_view s2 = "abc\0\0def"sv; std::cout << "s1.size(): " << s1.size() << "; s1: "; print_each_character(s1); std::cout << "s2.size(): " << s2.size() << "; s2: "; print_each_character(s2); std::cout << "substr(1, 4): " << "abcdef"sv.substr(1, 4) << '\n'; auto value_type_info = []<typename T>(T) { using V = typename T::value_type; std::cout << "sizeof " << typeid(V).name() << ": " << sizeof(V) << '\n'; }; value_type_info("char A"sv); value_type_info(L"wchar_t ∀"sv); value_type_info(u8"char8_t ∆"sv); value_type_info(u"char16_t ∇"sv); value_type_info(U"char32_t ∃"sv); value_type_info(LR"(raw ⊞)"sv); }
가능한 출력:
s1.size(): 3; s1: abc s2.size(): 8; s2: abc@@def substr(1, 4): bcde sizeof char: 1 sizeof wchar_t: 4 sizeof char8_t: 1 sizeof char16_t: 2 sizeof char32_t: 4 sizeof wchar_t: 4
참고 항목
basic_string_view
를 생성합니다
(public member function) |
|
|
(C++14)
|
문자 배열 리터럴을
basic_string
으로 변환합니다
(function) |